<template>
  <div>
    <h2>当前的和为: {{ sum }}</h2>
    <button @click="sum++">点我+1</button>
    <hr />
    <h2>当前的信息为: {{ msg }}</h2>
    <button @click="msg += '!'">修改当前信息</button>
    <hr />
    <h2>姓名: {{ person.name }}</h2>
    <h2>年龄: {{ person.age }}</h2>
    <h2>薪资: {{ person.job.j1.salary }}K</h2>
    <button @click="person.name += '!'">修改姓名</button>
    <button @click="person.age++">修改年龄</button>
    <button @click="person.job.j1.salary++">涨薪</button>
  </div>
</template>

<script>
import { ref, reactive, watch, watchEffect } from "vue";
export default {
  name: "Demo",

  setup() {
    let sum = ref(0);
    let msg = ref("你好呀");
    let person = reactive({
      name: "张三",
      age: 25,
      job: {
        j1: {
          salary: 6,
        },
      },
    });

    /***
     * 
     * watch的套路是：既要指明监视的属性，也要指明监视的回调。
       watchEffect的套路是：不用指明监视哪个属性，监视的回调中用到哪个属性，那就监视哪个属性
     * watchEffect有点像computed： 
            但computed注重的计算出来的值（回调函数的返回值），所以必须要写返回值。
            而watchEffect更注重的是过程（回调函数的函数体），所以不用写返回值。
     * 
     */
    watchEffect(() => {
      const x1 = sum.value;
      const x2 = person.job.j1.salary;
      console.log('watchEffect监听回调变化了!!!');
    })

   
    return {
      sum,
      msg,
      person,
    };
  },
};
</script>